## RISC-V Reference Sheet

|          | C           | General registers                | Floating Point Registers |          |             |                            |        |
|----------|-------------|----------------------------------|--------------------------|----------|-------------|----------------------------|--------|
| Register | ABI<br>Name | Description                      | Saver                    | Register | ABI<br>Name | Description                | Saver  |
| х0       | zero        | Constant zero                    |                          | f0       | ft0         | FP temporary               | Caller |
| x1       | ra          | Return address                   | Caller                   | f1       | ft1         | FP temporary               | Caller |
| x2       | sp          | Stack pointer                    | Callee                   | f2       | ft2         | FP temporary               | Caller |
| х3       | gp          | Global pointer                   | <u> </u>                 | f3       | ft3         | FP temporary               | Caller |
| х4       | tp          | Thread pointer                   |                          | f4       | ft4         | FP temporary               | Caller |
| x5       | t0          | Temporary                        | Caller                   | f5       | ft5         | FP temporary               | Caller |
| х6       | t1          | Temporary                        | Caller                   | f6       | ft6         | FP temporary               | Caller |
| x7       | t2          | Temporary                        | Caller                   | f7       | ft7         | FP temporary               | Caller |
| x8       | s0/fp       | Saved register / Frame pointer   | Callee                   | f8       | fs0         | FP saved register          | Callee |
| x9       | s1          | Saved register                   | Callee                   | f9       | fs1         | FP saved register          | Callee |
| x10      | a0          | Function argument / Return value | Caller                   | f10      | fa0         | FP argument / Return value | Caller |
| x11      | a1          | Function argument / Return value | Caller                   | f11      | fa1         | FP argument / Return value | Caller |
| x12      | a2          | Function argument                | Caller                   | f12      | fa2         | FP argument                | Caller |
| x13      | a3          | Function argument                | Caller                   | f13      | fa3         | FP argument                | Caller |
| x14      | a4          | Function argument                | Caller                   | f14      | fa4         | FP argument                | Caller |
| x15      | a5          | Function argument                | Caller                   | f15      | fa5         | FP argument                | Caller |
| x16      | a6          | Function argument                | Caller                   | f16      | fa6         | FP argument                |        |
| x17      | a7          | Function argument                | Caller                   | f17      | fa7         | FP argument                | Caller |
| x18      | s2          | Saved register                   | Callee                   | f18      | fs2         | FP saved register          | Callee |
| x19      | s3          | Saved register                   | Callee                   | f19      | fs3         | FP saved register          | Callee |
| x20      | s4          | Saved register                   | Callee                   | f20      | fs4         | FP saved register          | Callee |
| x21      | s5          | Saved register                   | Callee                   | f21      | fs5         | FP saved register          | Callee |
| x22      | s6          | Saved register                   | Callee                   | f22      | fs6         | FP saved register          | Callee |
| x23      | s7          | Saved register                   | Callee                   | f23      | fs7         | FP saved register          | Callee |
| x24      | s8          | Saved register                   | Callee                   | f24      | fs8         | FP saved register          | Callee |
| x25      | s9          | Saved register                   | Callee                   | f25      | fs9         | FP saved register          | Callee |
| x26      | s10         | Saved register                   | Callee                   | f26      | fs10        | FP saved register          | Callee |
| x27      | s11         | Saved register                   | Callee                   | f27      | fs11        | FP saved register          | Callee |
| x28      | t3          | Temporary                        | Caller                   | f28      | ft8         | FP temporary               | Caller |
| x29      | t4          | Temporary                        | Caller                   | f29      | ft9         | FP temporary               | Caller |
| x30      | t5          | Temporary                        | Caller                   | f30      | ft10        | FP temporary               | Caller |
| x31      | t6          | Temporary                        | Caller                   | f31      | ft11        | FP temporary               | Caller |

| Assembler Directives |                                                           |                                                               |  |  |  |  |  |  |
|----------------------|-----------------------------------------------------------|---------------------------------------------------------------|--|--|--|--|--|--|
| Directive            | Arguments                                                 | Description                                                   |  |  |  |  |  |  |
| .align               | integer                                                   | align to power of 2 (alias for .p2align)                      |  |  |  |  |  |  |
| .file                | "filename"                                                | emit filename FILE LOCAL symbol table                         |  |  |  |  |  |  |
| .globl               | symbol_name                                               | emit symbol_name to symbol table (scope GLOBAL)               |  |  |  |  |  |  |
| .local               | symbol_name                                               | emit symbol_name to symbol table (scope LOCAL)                |  |  |  |  |  |  |
| .common              | symbol_name,size,align                                    | emit common object to .bss section                            |  |  |  |  |  |  |
| .ident               | "string"                                                  | accepted for source compatibility                             |  |  |  |  |  |  |
| .section             | [{.text,.data,.rodata,.bss}]                              | emit section (if not present, default .text) and make current |  |  |  |  |  |  |
| .size                | symbol, symbol                                            | accepted for source compatibility                             |  |  |  |  |  |  |
| .text                |                                                           | emit .text section (if not present) and make current          |  |  |  |  |  |  |
| .data                |                                                           | emit .data section (if not present) and make current          |  |  |  |  |  |  |
| .rodata              |                                                           | emit .rodata section (if not present) and make current        |  |  |  |  |  |  |
| .bss                 |                                                           | emit .bss section (if not present) and make current           |  |  |  |  |  |  |
| .string              | "string"                                                  | emit string                                                   |  |  |  |  |  |  |
| .asciz               | "string"                                                  | emit string (alias for .string)                               |  |  |  |  |  |  |
| .equ                 | name, value                                               | constant definition                                           |  |  |  |  |  |  |
| .macro               | name arg1 [, argn]                                        | begin macro definition \argname to substitute                 |  |  |  |  |  |  |
| .endm                |                                                           | end macro definition                                          |  |  |  |  |  |  |
| .type                | symbol, @function                                         | accepted for source compatibility                             |  |  |  |  |  |  |
| .option              | {arch, rvc, norvc, pic, nopic, relax, norelax, push, pop} | RISC-V options                                                |  |  |  |  |  |  |
| .byte                | expression [, expression]*                                | 8-bit comma separated words                                   |  |  |  |  |  |  |
| .2byte               | expression [, expression]*                                | 16-bit comma separated words                                  |  |  |  |  |  |  |
| .4byte               | expression [, expression]*                                | 32-bit comma separated words                                  |  |  |  |  |  |  |
| .word                | expression [, expression]*                                | 32-bit comma separated words                                  |  |  |  |  |  |  |
| .8byte               | expression [, expression]*                                | 64-bit comma separated words                                  |  |  |  |  |  |  |
| .dword               | expression [, expression]*                                | 64-bit comma separated words                                  |  |  |  |  |  |  |
| .dtprelword          | expression [, expression]*                                | 32-bit thread local word                                      |  |  |  |  |  |  |
| .dtpreldword         | expression [, expression]*                                | 64-bit thread local word                                      |  |  |  |  |  |  |
| .sleb128             | expression                                                | signed little endian base 128, DWARF                          |  |  |  |  |  |  |
| .uleb128             | expression                                                | unsigned little endian base 128, DWARF                        |  |  |  |  |  |  |
| .p2align             | p2,[pad_val=0],max                                        | align to power of 2                                           |  |  |  |  |  |  |
| .balign              | b,[pad_val=0]                                             | byte align                                                    |  |  |  |  |  |  |
| .zero                | integer                                                   | zero bytes                                                    |  |  |  |  |  |  |
| .variant_cc          | symbol_name                                               | annotate the symbol with variant calling convention           |  |  |  |  |  |  |
| .attribute           | name, value                                               | RISC-V object attributes                                      |  |  |  |  |  |  |

| CSR Registers (Partial List) |           |            |                                                        |        |           |            |                                       |  |  |  |
|------------------------------|-----------|------------|--------------------------------------------------------|--------|-----------|------------|---------------------------------------|--|--|--|
| Number                       | Privilege | Name       | Description                                            | Number | Privilege | Name       | Description                           |  |  |  |
| 0x001                        | URW       | fflags     | Floating-Point Accrued Exceptions                      | 0x300  | MRW       | mstatus    | Machine status register               |  |  |  |
| 0x002                        | URW       | frm        | Floating-Point Dynamic Rounding Mode                   | 0x301  | MRW       | misa       | ISA and extensions                    |  |  |  |
| 0x003                        | URW       | fcsr       | Floating-Point Control and Status Register             | 0x302  | MRW       | medeleg    | Machine exception delegation register |  |  |  |
| 0xC00                        | URO       | cycle      | Cycle counter for RDCYCLE instruction                  | 0x302  | MRW       | mideleg    | Machine interrupt delegation register |  |  |  |
| 0xC01                        | URO       | time       | Timer for RDTIME instruction                           | 0x304  | MRW       | mie        | Machine interrupt-enable register     |  |  |  |
| 0xC02                        | URO       | instret    | Instructions-retired counter for RDINSTRET instruction | 0x305  | MRW       | mtvec      | Machine trap-handler base address     |  |  |  |
| 0xC80                        | URO       | cycleh     | Upper 32 bits of cycle, RV32 only                      | 0x306  | MRW       | mcounteren | Machine counter enable                |  |  |  |
| 0xC81                        | URO       | timeh      | Upper 32 bits of time, RV32 only                       | 0x341  | MRW       | mepc       | Machine exception program counter     |  |  |  |
| 0xC82                        | URO       | instreth   | Upper 32 bits of instret, RV32 only                    | 0x342  | MRW       | mcause     | Machine trap cause                    |  |  |  |
| 0xF11                        | MRO       | mvendorid  | Vendor ID                                              | 0x343  | MRW       | mtval      | Machine bad address or instruction    |  |  |  |
| 0xF12                        | MRO       | marchid    | Architecture ID                                        | 0x344  | MRW       | mip        | Machine interrupt pending             |  |  |  |
| 0xF13                        | MRO       | mimpid     | Implementation ID                                      | 0xB00  | MRW       | mcycle     | Machine cycle counter                 |  |  |  |
| 0xF14                        | MRO       | mhartid    | Hardware thread ID                                     | 0xB02  | MRW       | minstret   | Machine instructions-retired counter  |  |  |  |
| 0xF15                        | MRO       | mconfigptr | Pointer to configuration data structure                |        |           |            |                                       |  |  |  |

|        |                                          |      | RV32I Base Integer Instruct                  |                |                 |     |     |             |        |
|--------|------------------------------------------|------|----------------------------------------------|----------------|-----------------|-----|-----|-------------|--------|
| - ''   |                                          | Туре | Definition                                   | Fields         |                 |     |     |             |        |
| lui    | Load Upper Immediate                     | U    | R[rd] = {32'bimm[31], imm, 12'b0} imm[31:12] |                |                 |     |     | rd          | 011011 |
| auipc  | Add Upper Immediate to PC                | U    | R[rd] = PC + {imm, 12'b0}                    | imm[31:12]     |                 |     |     | rd          | 001011 |
| jal    | Jump And Link                            | J    | R[rd] = PC + 4; PC = PC + {imm, 1'b0}        | imm[20 10:1 1  | 1 19:12]        |     |     | rd          | 110111 |
| jalr   | Jump And Link Register                   | 1    | R[rd] = PC + 4; PC = PC + R[rs1] + imm       | imm[11:0]      | imm[11:0] rs1 0 |     |     | rd          | 110011 |
| beq    | Branch EQual                             | В    | if (R[rs1] == R[rs2]) PC = PC + {imm, 1'b0}  | imm[12 10:5]   | rs2             | rs1 | 000 | imm[4:1 11] | 110001 |
| bne    | Branch Not Equal                         | В    | if (R[rs1] != R[rs2]) PC = PC + {imm, 1'b0}  | imm[12 10:5]   | rs2             | rs1 | 001 | imm[4:1 11] | 110001 |
| blt    | Branch Less Than                         | В    | if (R[rs1] < R[rs2]) PC = PC + {imm, 1'b0}   | imm[12 10:5]   | rs2             | rs1 | 100 | imm[4:1 11] | 110001 |
| bge    | Branch Greater than or Equal             | В    | if (R[rs1] >= R[rs2]) PC = PC + {imm, 1'b0}  | imm[12 10:5]   | rs2             | rs1 | 101 | imm[4:1 11] | 110001 |
| bltu   | Branch Less Than Unsigned                | В    | if (R[rs1] < R[rs2]) PC = PC + {imm, 1'b0}   | imm[12 10:5]   | rs2             | rs1 | 110 | imm[4:1 11] | 110001 |
| bgeu   | Branch Greater than or Equal<br>Unsigned | В    | if (R[rs1] >= R[rs2]) PC = PC + {imm, 1'b0}  | imm[12 10:5]   | rs2             | rs1 | 111 | imm[4:1 11] | 110001 |
| lb     | Load Byte                                | T    | R[rd] = {24'bM[][7], M[R[rs1]+imm][7:0]}     | imm[11:0]      |                 | rs1 | 000 | rd          | 000001 |
| lh     | Load Halfword                            | I    | R[rd] = {16'bM[][7], M[R[rs1]+imm][15:0]}    | imm[11:0]      |                 | rs1 | 001 | rd          | 000001 |
| lw     | Load Word                                | T    | R[rd] = M[R[rs1]+imm][31:0]                  | imm[11:0]      |                 | rs1 | 010 | rd          | 000001 |
| lbu    | Load Byte Unsigned                       | T    | R[rd] = {24'b0, M[R[rs1]+imm][7:0]}          | <del>+</del>   |                 | rs1 | 100 | rd          | 000001 |
| lhu    | Load Halfword Unsigned                   | 1    | R[rd] = {16'b0, M[R[rs1]+imm][15:0]}         | imm[11:0] rs1  |                 | rs1 | 101 | rd          | 000001 |
| sb     | Store Byte                               | S    | M[R[rs1]+imm][7:0] = R[rs2][7:0]             | imm[11:5]      | rs2             | rs1 | 000 | imm[4:0]    | 010001 |
| sh     | Store Halfword                           | S    | M[R[rs1]+imm][15:0] = R[rs2][15:0]           | imm[11:5]      | rs2             | rs1 | 001 | imm[4:0]    | 010001 |
| SW     | Store Word                               | S    | M[R[rs1]+imm][31:0] = R[rs2][31:0]           | imm[11:5]      | rs2             | rs1 | 010 | imm[4:0]    | 010001 |
| addi   | ADD Immediate                            | ı    | R[rd] = R[rs1] + imm                         | +              |                 | rs1 | 000 | rd          | 001001 |
| slti   | Set Less Than Immediate                  | T    | R[rd] = (R[rs1] < imm) ? 1 : 0               | +              |                 | rs1 | 010 | rd          | 001001 |
| sltiu  | Set Less Than Immediate Unsigned         | 1    | R[rd] = (R[rs1] < imm) ? 1 : 0               | imm[11:0]      |                 | rs1 | 011 | rd          | 001001 |
| xori   | XOR Immediate                            | ı    | R[rd] = R[rs1] ^ imm                         | imm[11:0]      |                 | rs1 | 100 | rd          | 001001 |
| ori    | OR Immediate                             | ı    | R[rd] = R[rs1]   imm                         | imm[11:0]      |                 | rs1 | 110 | rd          | 001001 |
| andi   | AND Immediate                            | 1    | R[rd] = R[rs1] & imm                         | imm[11:0]      |                 | rs1 | 111 | rd          | 001001 |
| slli   | Shift Left Logical Immediate             | ı    | R[rd] = R[rs1] << imm                        | 0000000        | shamt           | rs1 | 001 | rd          | 001001 |
| srli   | Shift Right Logical Immediate            | ı    | R[rd] = R[rs1] >> imm                        | 0000000        | shamt           | rs1 | 101 | rd          | 001001 |
| srai   | Shift Right Arithmetic Immediate         | T    | R[rd] = R[rs1] >>> imm                       | 0100000        | shamt           | rs1 | 101 | rd          | 001001 |
| add    | ADD                                      | R    | R[rd] = R[rs1] + R[rs2]                      | 0000000        | rs2             | rs1 | 000 | rd          | 011001 |
| sub    | SUBtract                                 | R    | R[rd] = R[rs1] - R[rs2]                      | 0100000        | rs2             | rs1 | 000 | rd          | 011001 |
| sll    | Shift Left Logical                       | R    | R[rd] = R[rs1] << R[rs2]                     | 0000000        | rs2             | rs1 | 001 | rd          | 011001 |
| slt    | Set Less Than                            | R    | R[rd] = (R[rs1] < R[rs2]) ? 1 : 0            | 0000000        | rs2             | rs1 | 010 | rd          | 011001 |
| sltu   | Set Less Than Unsigned                   | R    | R[rd] = (R[rs1] < R[rs2]) ? 1 : 0            | 0000000        | rs2             | rs1 | 011 | rd          | 011001 |
| xor    | XOR                                      | R    | R[rd] = R[rs1] ^ R[rs2]                      | 0000000        | rs2             | rs1 | 100 | rd          | 011001 |
| srl    | Shift Right Logical                      | R    | R[rd] = R[rs1] >> R[rs2]                     | 0000000        | rs2             | rs1 | 101 | rd          | 011001 |
| sra    | Shift Right Arithmetic                   | R    | R[rd] = R[rs1] >>> R[rs2]                    | 0100000        | rs2             | rs1 | 101 | rd          | 011001 |
| or     | OR                                       | R    | R[rd] = R[rs1]   R[rs2]                      | 0000000        | rs2             | rs1 | 110 | rd          | 011001 |
| and    | AND                                      | R    | R[rd] = R[rs1] & R[rs2]                      | 0000000        | rs2             | rs1 | 111 | rd          | 011001 |
| fence  | Memory Ordering                          | ı    | Ensure correct ordering of memory operations | fm, pred, succ |                 | rs1 | 000 |             | 000111 |
| ecall  | Environment CALL                         | I    | Transfer control to operating system         | 0000000000     | 0               |     | 000 | 00000       | 111001 |
| ebreak | Environment BREAK                        |      | Transfer control to debugger                 | 00000000000    | <br>1           |     | 000 | 00000       | 111001 |

| Control and Status Register Instruction Extension (Zicsr) |                                                                                                                     |                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Name                                                      | Definition                                                                                                          | Fields                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| CSR Read and Write                                        | 1                                                                                                                   | R[rd] = CSR; CSR = R[rs1]                                                                                                               | csr                                                                                                                                                                                                                                                                                                                                                                                                                                                              | rs1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1110011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| CSR Read and Set                                          | 1                                                                                                                   | R[rd] = CSR; CSR = CSR   R[rs1]                                                                                                         | csr                                                                                                                                                                                                                                                                                                                                                                                                                                                              | rs1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1110011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| CSR Read and Clear                                        | 1                                                                                                                   | R[rd] = CSR; CSR = CSR & ~R[rs1]                                                                                                        | csr                                                                                                                                                                                                                                                                                                                                                                                                                                                              | rs1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 111001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| CSR Read and Write Immediate                              | 1                                                                                                                   | R[rd] = CSR; CSR = {27'b0, imm}                                                                                                         | csr                                                                                                                                                                                                                                                                                                                                                                                                                                                              | uimm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1110011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| CSR Read and Set Immediate                                | 1                                                                                                                   | R[rd] = CSR; CSR = CSR   {27'b0, imm}                                                                                                   | csr                                                                                                                                                                                                                                                                                                                                                                                                                                                              | uimm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1110011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| CSR Read and Clear Immediate                              | 1                                                                                                                   | R[rd] = CSR; CSR = CSR & ~{27'b0, imm}                                                                                                  | csr                                                                                                                                                                                                                                                                                                                                                                                                                                                              | uimm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1110011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|                                                           | Name CSR Read and Write CSR Read and Set CSR Read and Clear CSR Read and Write Immediate CSR Read and Set Immediate | Name Type  CSR Read and Write I  CSR Read and Set I  CSR Read and Clear I  CSR Read and Write Immediate I  CSR Read and Set Immediate I | Name         Type         Definition           CSR Read and Write         I         R[rd] = CSR; CSR = R[rs1]           CSR Read and Set         I         R[rd] = CSR; CSR = CSR   R[rs1]           CSR Read and Clear         I         R[rd] = CSR; CSR = CSR & ~R[rs1]           CSR Read and Write Immediate         I         R[rd] = CSR; CSR = {27'b0, imm}           CSR Read and Set Immediate         I         R[rd] = CSR; CSR = CSR   {27'b0, imm} | Name         Type         Definition         Fields           CSR Read and Write         I         R[rd] = CSR; CSR = R[rs1]         csr           CSR Read and Set         I         R[rd] = CSR; CSR = CSR   R[rs1]         csr           CSR Read and Clear         I         R[rd] = CSR; CSR = CSR & ~R[rs1]         csr           CSR Read and Write Immediate         I         R[rd] = CSR; CSR = {27'b0, imm}         csr           CSR Read and Set Immediate         I         R[rd] = CSR; CSR = CSR   {27'b0, imm}         csr | Name         Type         Definition         Fields           CSR Read and Write         I         R[rd] = CSR; CSR = R[rs1]         csr         rs1           CSR Read and Set         I         R[rd] = CSR; CSR = CSR   R[rs1]         csr         rs1           CSR Read and Clear         I         R[rd] = CSR; CSR = CSR & ~R[rs1]         csr         rs1           CSR Read and Write Immediate         I         R[rd] = CSR; CSR = {27'b0, imm}         csr         uimm           CSR Read and Set Immediate         I         R[rd] = CSR; CSR = CSR   {27'b0, imm}         csr         uimm | Name         Type         Definition         Fields           CSR Read and Write         I         R[rd] = CSR; CSR = R[rs1]         csr         rs1         001           CSR Read and Set         I         R[rd] = CSR; CSR = CSR   R[rs1]         csr         rs1         010           CSR Read and Clear         I         R[rd] = CSR; CSR = CSR & ~R[rs1]         csr         rs1         011           CSR Read and Write Immediate         I         R[rd] = CSR; CSR = {27'b0, imm}         csr         uimm         001           CSR Read and Set Immediate         I         R[rd] = CSR; CSR = CSR   {27'b0, imm}         csr         uimm         010 | Name         Type         Definition         Fields           CSR Read and Write         I         R[rd] = CSR; CSR = R[rs1]         csr         rs1         001         rd           CSR Read and Set         I         R[rd] = CSR; CSR = CSR   R[rs1]         csr         rs1         010         rd           CSR Read and Clear         I         R[rd] = CSR; CSR = CSR & ~R[rs1]         csr         rs1         011         rd           CSR Read and Write Immediate         I         R[rd] = CSR; CSR = {27'b0, imm}         csr         uimm         001         rd           CSR Read and Set Immediate         I         R[rd] = CSR; CSR = CSR   {27'b0, imm}         csr         uimm         010         rd |  |  |  |  |

| Inst. Name |                                          |   | Definition                             | Fields    |       |     |     |          |         |  |
|------------|------------------------------------------|---|----------------------------------------|-----------|-------|-----|-----|----------|---------|--|
| lwu        | Load Word Unsigned                       | 1 | R[rd] = M[R[rs1] + imm][31:0]          | imm[11:0] |       | rs1 | 110 | rd       | 000001  |  |
| ld         | Load Doubleword                          | 1 | R[rd] = M[R[rs1] + imm][63:0]          | imm[11:0] |       | rs1 | 011 | rd       | 000001  |  |
| sd         | Store Doubleword                         | S | M[R[rs1]+imm][63:0] = R[rs2]<br>[63:0] | imm[11:5] | rs2   | rs1 | 011 | imm[4:0] | 010001  |  |
| slli       | Shift Left Logical Immediate             | 1 | R[rd] = R[rs1] << imm                  | 000000    | shamt | rs1 | 001 | rd       | 001001  |  |
| srli       | Shift Right Logical Immediate            | 1 | R[rd] = R[rs1] >> imm                  | 000000    | shamt | rs1 | 101 | rd       | 001001  |  |
| srai       | Shift Right Arithmetic Immediate         | 1 | R[rd] = R[rs1] >>> imm                 | 010000    | shamt | rs1 | 101 | rd       | 001001  |  |
| addiw      | ADD Immediate Word                       | 1 | R[rd] = R[rs1] + imm                   | imm[11:0] |       | rs1 | 000 | rd       | 001001  |  |
| slliw      | Shift Left Logical Immediate Word        | ı | R[rd] = R[rs1] + imm                   | 0000000   | shamt | rs1 | 001 | rd       | 001001  |  |
| srli       | Shift Right Logical Immediate Word       | ı | R[rd] = R[rs1] >> imm                  | 0000000   | shamt | rs1 | 101 | rd       | 001001  |  |
| srai       | Shift Right Arithmetic Immediate<br>Word | ı | R[rd] = R[rs1] >>> imm                 | 0100000   | shamt | rs1 | 101 | rd       | 001001  |  |
| addw       | ADD Word                                 | R | R[rd] = R[rs1] + R[rs2]                | 0000000   | rs2   | rs1 | 000 | rd       | 011101  |  |
| subw       | SUBtract Word                            | R | R[rd] = R[rs1] - R[rs2]                | 0100000   | rs2   | rs1 | 000 | rd       | 011101  |  |
| sllw       | Shift Left Logical Word                  | R | R[rd] = R[rs1] << R[rs2]               | 0000000   | rs2   | rs1 | 001 | rd       | 011101  |  |
| srlw       | Shift Right Logical Word                 | R | R[rd] = R[rs1] >> R[rs2]               | 0000000   | rs2   | rs1 | 101 | rd       | 011101  |  |
| sraw       | Shift Right Arithmetic Word              | R | R[rd] = R[rs1] >>> R[rs2]              | 0100000   | rs2   | rs1 | 101 | rd       | 0111011 |  |

| Integer Multiplication and Division Extension (M) |                                       |      |                                  |  |  |  |  |  |  |
|---------------------------------------------------|---------------------------------------|------|----------------------------------|--|--|--|--|--|--|
| Inst.                                             | Name                                  | Туре | Definition                       |  |  |  |  |  |  |
| mul                                               | MULtiply                              | R    | R[rd] = (R[rs1] * R[rs2])[31:0]  |  |  |  |  |  |  |
| mulh                                              | MULtiply High                         | R    | R[rd] = (R[rs1] * R[rs2])[63:32] |  |  |  |  |  |  |
| mulhsu                                            | MULtiply upper Half Signed / Unsigned | R    | R[rd] = (R[rs1] * R[rs2])[63:32] |  |  |  |  |  |  |
| mulhu                                             | MULtiply High Unsigned                | R    | R[rd] = (R[rs1] * R[rs2])[63:32] |  |  |  |  |  |  |
| div                                               | DIVide                                | R    | R[rd] = R[rs1] / R[rs2]          |  |  |  |  |  |  |
| divu                                              | DIVide Unsigned                       | R    | R[rd] = R[rs1] / R[rs2]          |  |  |  |  |  |  |
| rem                                               | REMainder                             | R    | R[rd] = R[rs1] % R[rs2]          |  |  |  |  |  |  |
| remu                                              | REMainder Unsigned                    | R    | R[rd] = R[rs1] % R[rs2]          |  |  |  |  |  |  |

| Atomic Instruction Extension (A) |                                      |      |                                                              |  |  |  |  |  |  |  |
|----------------------------------|--------------------------------------|------|--------------------------------------------------------------|--|--|--|--|--|--|--|
| Inst.                            | Name                                 | Туре | Definition                                                   |  |  |  |  |  |  |  |
| lr.w                             | Load Reserved                        | R    | R[rd] = M[R[rs1]], reservation on M[R[rs1]]                  |  |  |  |  |  |  |  |
| SC.W                             | Store Conditional                    | R    | if reserved, M[R[rs1]] = R[rs2], R[rd] = 0; else R[rd] = 1   |  |  |  |  |  |  |  |
| amoswap.w                        | Atomic Memory Operation SWAP         | R    | R[rd] = M[R[rs1]], M[R[rs1]] = R[rs2]                        |  |  |  |  |  |  |  |
| amoadd.w                         | Atomic Memory Operation ADD          | R    | R[rd] = M[R[rs1]], M[R[rs1]] = M[R[rs1]] + R[rs2]            |  |  |  |  |  |  |  |
| amoxor.w                         | Atomic Memory Operation XOR          | R    | R[rd] = M[R[rs1]], M[R[rs1]] = M[R[rs1]] ^ R[rs2]            |  |  |  |  |  |  |  |
| amoand.w                         | Atomic Memory Operation AND          | R    | R[rd] = M[R[rs1]], M[R[rs1]] = M[R[rs1]] & R[rs2]            |  |  |  |  |  |  |  |
| amoxor.w                         | Atomic Memory Operation OR           | R    | R[rd] = M[R[rs1]], M[R[rs1]] = M[R[rs1]]   R[rs2]            |  |  |  |  |  |  |  |
| amomin.w                         | Atomic Memory Operation MIN          | R    | R[rd] = M[R[rs1]], if(R[rs2] < M[R[rs1]]) M[R[rs1]] = R[rs2] |  |  |  |  |  |  |  |
| amomax.w                         | Atomic Memory Operation MAX          | R    | R[rd] = M[R[rs1]], if(R[rs2] > M[R[rs1]]) M[R[rs1]] = R[rs2] |  |  |  |  |  |  |  |
| amominu.w                        | Atomic Memory Operation MIN Unsigned | R    | R[rd] = M[R[rs1]], if(R[rs2] < M[R[rs1]]) M[R[rs1]] = R[rs2] |  |  |  |  |  |  |  |
| amomaxu.w                        | Atomic Memory Operation MAX Unsigned | R    | R[rd] = M[R[rs1]], if(R[rs2] > M[R[rs1]]) M[R[rs1]] = R[rs2] |  |  |  |  |  |  |  |

| 1 | Instruction–Fetch Fence Extension (Zifencei) |                         |      |                                              |  |  |  |  |  |  |
|---|----------------------------------------------|-------------------------|------|----------------------------------------------|--|--|--|--|--|--|
| 1 | Inst.                                        | Name                    | Туре | Definition                                   |  |  |  |  |  |  |
| 1 | fence.i                                      | Fence Instruction-fetch | 1    | Ensure correct ordering of instruction fetch |  |  |  |  |  |  |

| Single-Precision Floating Point Extension (F) |                                      |      |                                                     |  |  |  |  |  |  |
|-----------------------------------------------|--------------------------------------|------|-----------------------------------------------------|--|--|--|--|--|--|
| Inst.                                         | Name                                 | Туре | Definition                                          |  |  |  |  |  |  |
| flw                                           | Load Word                            | 1    | F[rd] = M[R[rs1] + imm]                             |  |  |  |  |  |  |
| fsw                                           | Store Word                           | S    | M[R[rs1] + imm] = F[rd]                             |  |  |  |  |  |  |
| fmadd.s                                       | Multiply-ADD                         | R    | F[rd] = F[rs1] * F[rs2] + F[rs3]                    |  |  |  |  |  |  |
| fmsub.s                                       | Multiply-SUBtract                    | R    | F[rd] = F[rs1] * F[rs2] - F[rs3]                    |  |  |  |  |  |  |
| fnmsub.s                                      | Negative Multiply-SUBtract           | R    | F[rd] = -(F[rs1] * F[rs2] - F[rs3])                 |  |  |  |  |  |  |
| fnmadd.s                                      | Negative Multiply-ADD                | R    | F[rd] = -(F[rs1] * F[rs2] + F[rs3])                 |  |  |  |  |  |  |
| fadd.s                                        | ADD                                  | R    | F[rd] = F[rs1] + F[rs2]                             |  |  |  |  |  |  |
| fsub.s                                        | SUBtract                             | R    | F[rd] = F[rs1] - F[rs2]                             |  |  |  |  |  |  |
| fmul.s                                        | MULtiply                             | R    | F[rd] = F[rs1] * F[rs2]                             |  |  |  |  |  |  |
| fdiv.s                                        | DIVide                               | R    | F[rd] = F[rs1] / F[rs2]                             |  |  |  |  |  |  |
| fsqrt.s                                       | SQuare RooT                          | R    | F[rd] = sqrt(F[rs1])                                |  |  |  |  |  |  |
| fsgnj.s                                       | SiGN source                          | R    | F[rd] = {F[rs2][31], F[rs1][30:0]}                  |  |  |  |  |  |  |
| fsgnjn.s                                      | Negative SiGN source                 | R    | F[rd] = {~F[rs2][31], F[rs1][30:0]}                 |  |  |  |  |  |  |
| fsgxjn.s                                      | Xor SiGN source                      | R    | F[rd] = {F[rs2][31] ^ F[rs1][31], F[rs1]<br>[30:0]} |  |  |  |  |  |  |
| fmin.s                                        | MIN                                  | R    | F[rd] = (F[rs1] < F[rs2]) ? F[rs1] : F[rs2]         |  |  |  |  |  |  |
| fmax.s                                        | MAX                                  | R    | F[rd] = (F[rs1] > F[rs2]) ? F[rs1] : F[rs2]         |  |  |  |  |  |  |
| fcvt.w.s                                      | Convert to 32b Integer               | R    | R[rd] = integer(F[rs1])                             |  |  |  |  |  |  |
| fcvt.wu.s                                     | Convert to 32b Integer Unsigned      | R    | R[rd] = integer(F[rs1])                             |  |  |  |  |  |  |
| fmv.x.w                                       | Move to Integer                      | R    | R[rd] = F[rs1]                                      |  |  |  |  |  |  |
| feq.s                                         | Compare Float EQual                  | R    | R[rd] = (F[rs1] == F[rs2]) ? 1:0                    |  |  |  |  |  |  |
| flt.s                                         | Compare Float Less Than              | R    | R[rd] = (F[rs1] < F[rs2]) ? 1 : 0                   |  |  |  |  |  |  |
| fle.s                                         | Compare Float Less than or Equal     | R    | R[rd] = (F[rs1] <= F[rs2]) ? 1 : 0                  |  |  |  |  |  |  |
| fclass.s                                      | Classify Type                        | R    | R[rd] = class(F[rs1])                               |  |  |  |  |  |  |
| fcvt.s.w                                      | Convert from 32b Integer             | R    | F[rd] = float(R[rs1])                               |  |  |  |  |  |  |
| fcvt.s.wu                                     | Convert from 32b Integer<br>Unsigned | R    | F[rd] = float(R[rs1])                               |  |  |  |  |  |  |
| fmv.w.x                                       | Move from Integer                    | R    | F[rs1] = R[rd]                                      |  |  |  |  |  |  |

